# Санкт-Петербургский Политехнический Университет Петра Великого Институт Компьютерных наук и технологий Кафедра компьютерных систем и программных технологий

Лабораторная работа 13 Задание 2 Предмет: «Проектирование реконфигурируемых гибридных вычислительных систем» **Тема: «Сравнение типов данных»** 

Студент: Ерниязов Т.Е. Гр. № 3540901/81502

Преподаватель: Антонов А.П.

# Оглавление

| 1.   | Задание                    | 4 |
|------|----------------------------|---|
|      | Исходный код               |   |
| 3.   | Первое решение             | 7 |
| 3.1. | Моделирование              | 7 |
| 4.   | Второе решение             | 7 |
| 4.1. | Моделирование              | 7 |
| 4    | .2. Синтез                 | 7 |
| 4    | .3. Использование ресурсов | 8 |
| 5    | . Выводы                   | 9 |

#### 1. Задание

- Создать проект lab13\_2
- Микросхема: ха7а12tcsg325-1q
- В папке source текст функции apint\_promotion Познакомьтесь с ним.
- Познакомьтесь с тестом.
- Исследование:
- Solution 1a
  - о Создать версию apint\_, в которой будет убран Кастинг

```
#include "apint_promotion.h"
|dout_t apint_promotion(din_t a,din_t b) {
    dout_t tmp;

tmp = (dout_t)a * (dout_t)b;
    return tmp;
}
```

- о Осуществить моделирование (при необходимости изменить тест)
- о задать: clock period 10; clock\_uncertainty 0.1
- о установить реализацию ПО УМОЛЧАНИЮ
- о осуществить синтез для:
  - привести в отчете:
    - performance estimates=>summary (timing, latency)
    - utilization estimates=>summary
    - performance Profile
    - Resource profile
    - scheduler viewer (выполнить Zoom to Fit)
      - о На скриншоте показать Latency
      - о На скриншоте показать Initiation Interval
    - resource viewer (выполнить Zoom to Fit)
      - о На скриншоте показать Latency
      - о На скриншоте показать Initiation Interval
- о Выполнить cosimulation и привести временную диаграмму
- Solution 2a
  - о Использовать исходную функцию apint\_promotion
  - о Осуществить моделирование
  - о задать: clock period 10; clock\_uncertainty 0.1
  - о установить реализацию ПО УМОЛЧАНИЮ
  - о осуществить синтез
    - привести в отчете:

- performance estimates=>summary (timing, latency)
- utilization estimates=>summary
- performance Profile
- Resource profile
- scheduler viewer (выполнить Zoom to Fit)
  - о На скриншоте показать Latency
  - о На скриншоте показать Initiation Interval
- resource viewer (выполнить Zoom to Fit)
  - о На скриншоте показать Latency
  - о На скриншоте показать Initiation Interval
- о Выполнить cosimulation и привести временную диаграмму
- Сравнить два решения (solution\_1a и solution\_2a) и сделать выводы

#### 2. Исходный код

```
#include "apint_promotion.h"

dout_t apint_promotion(din_t a,din_t b) {
    dout_t tmp;
    #ifndef ENABLE_TYPE_CAST
    tmp = (dout_t)a * (dout_t)b;

#else
    tmp = a * b;

#endif
    return tmp;
}
```

Рис. 2.1. Source code

```
#ifndef _APINT_PROMOTION_H
#define _APINT_PROMOTION_H

#include <stdio.h>
#include "ap_cint.h"

typedef int18 din_t;
typedef int36 dout_t;

dout_t apint_promotion(din_t a,din_t b);

#endif
```

Рис. 2.2. Source code - header

Рис. 2.1.3. Test code

#### 3. Первое решение

#### 3.1. Моделирование

По результатам моделирования видно, что устройство работает не корректно.

Рис. 3.1. Modeling result

## 4. Второе решение

#### 4.1. Моделирование

```
🖳 Console 🖾 😢 Errors 🐧 Warnings 🖆 DRCs
Vivado HLS Console
Starting C simulation ...
 :/Xilinx/Vivado/2019.2/bin/vivado_hls.bat C:/Users/Misha/Desktop/university/__maga/3sem
INFO: [HLS 200-10] Running 'C:/Xilinx/Vivado/2019.2/bin/unwrapped/win64.o/vivado_hls.exe
INFO: [HLS 200-10] For user 'Misha' on host 'mikhail' (Windows NT amd64 version 6.2) on
INFO: [HLS 200-10] In directory 'C:/Users/Misha/Desktop/university/_maga/3sem/antonov/l
Sourcing Tcl script 'C:/Users/Misha/Desktop/university/_maga/3sem/antonov/lab13/lab13_z
INFO: [HLS 200-10] Opening project 'C:/Users/Misha/Desktop/university/_maga/3sem/antono
INFO: [HLS 200-10] Opening solution 'C:/Users/Misha/Desktop/university/ maga/3sem/anton
INFO: [SYN 201-201] Setting up clock 'default' with a period of 10ns.
INFO: [SYN 201-201] Setting up clock 'default' with an uncertainty of 0.1ns.
WARNING: [HLS 200-40] Cannot find library 'C:/Xilinx/Vivado/2019.2/common/technology/xil WARNING: [HLS 200-40] Cannot find library 'xilinx/aartix7/aartix7'.
INFO: [HLS 200-10] Setting target device to 'xa7a12t-csg325-1Q'
INFO: [SIM 211-4] CSIM will launch GCC as the compiler.
make: 'csim.exe' is up to date.
Test passed !
Finished C simulation.
```

Рис. 4.1. Performance estimates

#### 4.2. Синтез



Рис. 4.2. Performance estimates

## 4.3. Использование ресурсов



Рис. 4.3.1. Utilization estimates



Рис. 4.3.2. Performance profile



Рис. 4.3.3. Resource profile



Рис. 2.4.4. Schedule viewer



Рис. 2.4.5. Resource viewer

#### 5. Выводы

В ходе выполнения работы была продемонстрирована важность порядка преобразования типов. В первом решении, операция умножения выполняется для двух операндов с типом d\_in, который значительно меньше, чем d\_out. Во время умножения происходит переполнение, и результат оказывается некорректным. Во втором решении, умножение выполняется над операндами с типом d\_out, так как произведено явное преобразование типов. Этот тип более вместительный, и переполнения не происходит.